

A<sup>19</sup>

19. (AMENDED) The computer-readable medium of Claim 18 wherein said microcontroller is designed according to a programmable single-chip architecture.

IN THE DRAWINGS

Applicant respectfully requests approval of the drawing change to Fig. 2A shown in the attached Request for Approval of Drawing Changes.

AMENDMENTS WITH CHANGES SHOWN:

IN THE SPECIFICATION

Please replace the paragraph beginning at page 2, line 7 with the following new paragraph:  
  
To overcome these problems, microcontroller suppliers (specifically, Cypress [Microsystems] MicroSystems, Inc., in Bothell, Washington) have started to offer standard parts that combine a microprocessor with several user-configurable “building blocks.” These building blocks may be assembled, configured and programmed to form many standard microprocessor peripherals, as well as to form unique peripherals as may be required by a specific application. Thus, a user can tailor a microcontroller to meet his or her specific requirements, in less time and at less cost than through other means. A microcontroller assembled from these building blocks is referred to herein as a programmable single-chip system [on a chip (PSoC)]. Additional information regarding [PSoCs] such a microcontroller is provided in the co-pending, commonly-owned US Patent Application, Attorney Docket No. CYPR-CD00232, Serial No. [ ] 10/033,027, filed October 22, 2001, by W. Snyder, and entitled “Programmable Microcontroller [Programmable System on a Chip] Architecture,” hereby incorporated by reference.

Please replace the paragraph beginning at page 4, line 17 with the following new paragraph:

Thus, what is needed is a method or system that can help guide a user through a series of tasks in an orderly manner while facilitating movement between tasks. What is also needed is a method or system that can satisfy the above need and that can be used for the design of microcontrollers, such as microcontrollers of the [PSoC] design mentioned above. The present invention provides a novel solution to these needs.

Please replace the paragraph beginning at page 8, line 9 with the following new paragraph:

Figure 2A is a block diagram of an exemplary programmable single-chip system [on a chip (SoC)] architecture used with one embodiment of the present invention.

Please replace the paragraph beginning at page 8, line 12 with the following new paragraph:

Figure 2B is a block diagram of an exemplary arrangement of [SoC] programmable system blocks used with one embodiment of the present invention.

Please replace the paragraph beginning at page 13, line 11 with the following new paragraph:

The present invention is described in the context of a software tool, portions of which are comprised of computer-readable and computer-executable instructions which reside, for example, in computer-readable media of a computer system such as that exemplified by Figure 1. The present invention is primarily described as being used with a tool for designing, configuring, programming, compiling, building (assembling), emulating, and debugging an embedded microcontroller, in particular a class of microcontrollers that provide analog and/or digital subsystems comprising many dynamically configurable blocks. An example of this class is referred to herein as a programmable microcontroller architecture [system on a chip (PSoC)]. Additional information regarding [PSoCs] such an architecture is provided in the co-pending, commonly-owned US Patent Application, Attorney Docket No. CYPR-CD00232, Serial No. [ ] 10/033,027, filed October 22, 2001,

by W. Snyder, and entitled “Programmable Microcontroller [Programmable System on a Chip] Architecture,” hereby incorporated by reference.

Please replace the paragraph beginning at page 14, line 4 with the following new paragraph:

Figure 2A is a block diagram of an integrated circuit (or microcontroller) 210 that exemplifies a microcontroller which uses [the PSoC] a programmable architecture. In the illustrated embodiment, integrated circuit 210 includes a system bus 211, and coupled to bus 211 are synchronous random access memory (SRAM) 212 for storing volatile or temporary data during firmware execution, central processing unit (CPU) 214 for processing information and instructions, flash read-only memory (ROM) 216 for holding instructions (e.g., firmware), input/output (I/O) pins 218 providing an interface with external devices and the like, and system [on a chip (SoC)] blocks 225. The [SoC] system blocks 225 include analog blocks and digital blocks.

Please replace the paragraph beginning at page 14, line 15 with the following new paragraph:

Referring to Figure 2B, an embodiment of [SoC] system block 225 is depicted in greater detail. In this embodiment, [SoC] system block 225 includes an analog functional block 230, a digital functional block 240, and a programmable interconnect 250. Analog block 230 includes, in the present embodiment, a matrix of interconnected analog blocks A1 through AN. The number N may be any number of analog blocks. Likewise, digital block 240 includes, in the present embodiment, a matrix of interconnected digital blocks D1 through DM. The number M may be any number of digital blocks. The analog blocks A1 through AN and the digital blocks D1 through DM are fundamental building blocks that may be combined in different ways to accomplish different functions. Importantly, different combinations of blocks, producing different functions, may exist at different times within the same system. For example, a set of blocks configured to perform the function of analog-to-digital conversion may sample a signal. After processing that signal in the

digital domain, those same blocks (perhaps in conjunction with a few others) may be recombined in a different configuration to perform the function of digital-to-analog conversion to produce an output signal.

Please replace the paragraph beginning at page 16, line 4 with the following new paragraph:

With reference next to Figure 3, process 300 illustrates exemplary steps used by a microcontroller design tool in accordance with one embodiment of the present invention. The purpose of process 300 is to configure, program, compile, build, emulate and debug a customized microcontroller (a “target device”) based on the integrated circuit 210 and [SoC] system blocks 225 of Figures 2A and 2B.

Please replace the paragraph beginning at page 17, line 7 with the following new paragraph:

In step 310, applicable “user modules” are selected. A user module, as used herein, is a preconfigured function that may be based on more than one [SoC blocks] system block. A user module, once placed and programmed, will work as a peripheral on the target device. At any time in process 300, user modules may be added to or removed from the target device.

Please replace the paragraph beginning at page 17, line 13 with the following new paragraph:

The selected user modules can then be “placed” or “mapped” onto the [SoC] system blocks 225 of Figure 2B. Once a user module is placed, its parameters can be viewed and modified as needed. Global parameters used by all of the user modules (for example, CPU clock speed) can also be set.

Please replace the paragraph beginning at page 17, line 18 with the following new paragraph:

Continuing with step 310 of Figure 3, interconnections between the selected user modules can be specified, either as each user module is placed or afterwards. The pin-out for each [PSoC] programmable system block can be specified, making a connection between the software configuration and the hardware of the target device.

Please replace the paragraph beginning at page 21, line 4 with the following new paragraph:

In the present embodiment, some of the elements are always active, regardless of which task is being performed (or which window or workspace is open). As depicted in Figure 4A, the three elements A, B and C are active at all times, and the other elements are not active. For example, the microcontroller design tool described in conjunction with Figure 3 is, in one embodiment, divided into at least three subsystems: a Device Editor subsystem, an Application Editor subsystem, and a Debugger subsystem. In essence, the Device Editor subsystem implements steps 310-320 of Figure 3, the Application Editor subsystem implements steps 330-340 of Figure 3, and the Debugger subsystem implements step 360 of Figure 3. According to the present invention, an element is associated with each of these subsystems, and the element for each subsystem is always active, regardless of which subsystem is being used for the task at hand. Thus, a user can readily move between various tasks (or windows or workspaces) by selecting the appropriate active element. For example, in the microcontroller design tool, the user can move from the Debugger subsystem back to the Device Editor subsystem without having to pass through the Application Editor subsystem.

Please replace the paragraph beginning at page 21, line 21 with the following new paragraph:

Another feature of the [presentation] present invention is that the graphic elements are rendered in GUI 400 in locations that correspond to the logical order in which tasks should be performed. For example, as described above, in the microcontroller design tool, the Device Editor subsystem implements steps 310-320 of Figure 3, the Application Editor subsystem implements

steps 330-340 of Figure 3, and the Debugger subsystem implements step 360 of Figure 3. In accordance with the present invention, element A is associated with the Device Editor subsystem, element B with the Application Editor subsystem, and element C with the Debugger subsystem. The order of the graphic elements is used to suggest to the user the order in which the subsystems are to be accessed.

Please replace the paragraph beginning at page 22, line 16 with the following new paragraph:

Figure 4B is described further by way of example. In the microcontroller design tool, a user can select a user module and place it using the Device Editor subsystem (refer to step 310 of Figure 3). To accomplish this, the user selects element A (for example) to implement the Device Editor subsystem. In response to this selection, elements for the user module selection task and for the user module placement task (e.g., elements A1 and A2) are activated. Other elements may also be activated for the other tasks that can be performed using the Device Editor subsystem.

Please replace the paragraph beginning at page 23, line 1 with the following new paragraph:

Thus, similar to that described above, elements are presented to the user in such a way so as to guide the user through the tasks in a logical order; for example, the user module selection task and the user module placement task are not activated until the user implements the Device Editor subsystem. As well, the elements are placed to suggest to the user a logical order for performing the tasks. That is, for example, the elements for the user module selection task and for the user module placement task are proximate to each other, implying a relationship between the tasks. Also, the element for the user module selection task is placed to the left of the element for the user module placement task, implying an order in which the tasks should be performed.

Please replace the paragraph beginning at page 25, line 7 with the following new paragraph:

It is appreciated that, in response to user selection of element B, not all of the elements A1-A4 may be deactivated. For example, element A1 may remain active. In this manner, a shortcut is created between tasks. For instance, in the microcontroller design tool in which element A is associated with the Device Editor subsystem and element B is associated with the Application Editor subsystem, a user may move from a task in the Application Editor subsystem directly to a task in the Device Editor subsystem without traversing through all of the intervening tasks. For example, the user can move directly between a task associated with any of the elements B1-B4 to the task associated with element A1, and vice versa. Thus, the user does not have to leave a task in the Application Editor subsystem, enter the Device Editor subsystem, next enter a specific task within the Device Editor subsystem, and then reverse these steps to return to the task in the Application Editor subsystem; instead, the user moves directly to the task in the Device Editor subsystem, then directly back to the task in the Application Editor subsystem. However, the user is still presented with only a limited number of choices that are intelligently selected and enforced by activating and deactivating certain elements. Thus, as opposed to a conventional wizard approach, a user has greater flexibility and freedom of movement, but the user is still provided with a degree of organization and guidance, in contrast to a conventional free form approach.

IN THE CLAIMS

3. (AMENDED) The method of Claim 2 wherein said microcontroller is designed according to a programmable [system on] single-chip architecture.

11. (AMENDED) The computer system of Claim 10 wherein said microcontroller is designed according to a programmable [system on] single-chip architecture.

19. (AMENDED) The computer-readable medium of Claim 18 wherein said microcontroller is designed according to a programmable [system on] single-chip architecture.

SUPPORT FOR AMENDMENTS

Support for the amendments herein can be found throughout the specification as originally filed and in co-pending, commonly-owned US Patent Application Serial No. 10/033,027, filed October 22, 2001. The present amendment intends to remove references to the trademarks of Cypress MicroSystems, Inc. (see, e.g., M.P.E.P. § 608.01(v) and the attached printouts from <http://tess.uspto.gov/>, notably the “PSOC” trademark registration information therein, and [http://www.cypressmicro.com/corporate/CY\\_Announces\\_nov\\_13\\_2000.html](http://www.cypressmicro.com/corporate/CY_Announces_nov_13_2000.html).) No new matter is introduced.